package com.rock.code.system.dic.controller;

import com.alibaba.fastjson.JSONObject;
import com.github.pagehelper.PageInfo;
import com.rock.code.base.controller.BaseController;
import com.rock.code.base.domain.AjaxJson;
import com.rock.code.base.domain.Constants;
import com.rock.code.common.excel.ExportExcel;
import com.rock.code.common.exceptions.SystemException;
import com.rock.code.common.pager.Page;
import com.rock.code.system.dic.domain.TbSysDic;
import com.rock.code.system.dic.service.TbSysDicService;
import com.rock.code.system.user.domain.TbSysLoginmsg;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
* 字典管理
*
* @author wangwenbo
* @date 2018/01/18
*/
@Controller
@RequestMapping("/tbSysDic")
public class TbSysDicController extends BaseController {

    /**
    * The tbSysDicServiceImpl
    */
    @Resource
    private TbSysDicService tbSysDicServiceImpl;

    /**
    * Dispatch.
    *
    * @return the string
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @RequestMapping("")
    public String dispatch() throws Exception {
        return "system/dic/tbSysDicList";
    }

    /**
    * queryPageList
    *
    * @return the page info
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/queryPageList", method = RequestMethod.POST)
    public PageInfo<TbSysDic> queryPageList() throws Exception {
        Map<String, Object> param = this.getRequestMapSingle();
        Page page = new Page(request);
        PageInfo pageInfo = null;
        try {
            param.put("isDelete", Constants.DELETE_N);
            pageInfo = tbSysDicServiceImpl.queryPageList(page, param);
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
        return pageInfo;
    }

    /**
    * querySingle
    *
    * @return TbSysDic
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/querySingle", method = RequestMethod.POST)
    public TbSysDic querySingle() throws Exception {
        Map<String, Object> param = this.getRequestMapSingle();
        TbSysDic tbSysDic = null;
        try {
            tbSysDic = tbSysDicServiceImpl.queryByParaMap(param);
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
        return tbSysDic;
    }

    /**
    * Save.
    *
    * @param tbSysDic the TbSysDic
    * @return the ajax json
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/save", method = RequestMethod.POST)
    public AjaxJson save(@RequestBody TbSysDic tbSysDic) throws Exception {
        try {
            TbSysLoginmsg sessionUser = getSessionUser();
            if (isNotEmpty(tbSysDic.getDicId())) {
                tbSysDic.setModifier(sessionUser.getLoginCode());
                tbSysDic.setModifieDate(new Date());
                tbSysDicServiceImpl.update(tbSysDic);
            } else {
                tbSysDic.setIsDelete(Constants.DELETE_N);
                tbSysDic.setIsView(new Integer(1));
                tbSysDic.setCreater(sessionUser.getLoginCode());
                tbSysDic.setCreateDate(new Date());
                tbSysDic.setModifier(sessionUser.getLoginCode());
                tbSysDic.setModifieDate(new Date());
                tbSysDicServiceImpl.insert(tbSysDic);
            }
            return ajaxJson;
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
    }

    /**
    * Delete.
    *
    * @param ids the ids
    * @return the ajax json
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/delete", method = RequestMethod.POST)
    public AjaxJson delete(@RequestParam String ids) throws Exception {
        try {
            String[] dicIds = ids.split(",");
            TbSysLoginmsg sessionUser = getSessionUser();
            for (String dicId : dicIds) {
                TbSysDic tbSysDic = new TbSysDic();
                tbSysDic.setDicId(dicId);
                tbSysDic.setIsDelete(Constants.DELETE_Y);
                tbSysDic.setModifier(sessionUser.getLoginCode());
                tbSysDic.setModifieDate(new Date());
                tbSysDicServiceImpl.update(tbSysDic);
            }
            return ajaxJson;
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
    }

    /**
    * Exp excel.
    *
    * @return the ajax json
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/expExcel", method = RequestMethod.POST)
    public AjaxJson expExcel() throws Exception {
        try {
            Map<String, Object> param = this.getRequestMapSingle();
            String[] titles = (String[]) param.get("titles[]");
            String[] fields = (String[]) param.get("fields[]");
            Page page = new Page((String) param.get("sidx"), (String) param.get("sord"));
            param.put("isDelete", Constants.DELETE_N);
            ExportExcel ee = new ExportExcel();
            List rows = tbSysDicServiceImpl.queryListByOrder(page, param);
            String path = ee.exportExcel(request, response, 40000, titles, fields, rows, TbSysDic.class.getName());
            ajaxJson.setResult(path);
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
        return ajaxJson;
    }

    /**
    * Check input field.
    *
    * @param inputName the input name
    * @param inputValue the input value
    * @return the json object
    * @throws Exception the exception
    * @author wangwenbo
    * @date 2018/01/18
    */
    @ResponseBody
    @RequestMapping(value = "/checkInputField", method = RequestMethod.POST)
    public JSONObject checkInputField(String inputName, String inputValue) throws Exception {
        try {
            Map<String, Object> param = new HashMap<String, Object>();
            param.put(inputName, inputValue);
            param.put("isDelete", Constants.DELETE_N);
            List rows = tbSysDicServiceImpl.queryListByParaMap(param);
            if (rows != null && rows.size() > 0) {
                json.put("valid", false);
            } else {
                json.put("valid", true);
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new SystemException(e);
        }
        return json;
    }
}
